package cn.stylefeng.guns.sys.modular.dbservicedetails.service;

import cn.stylefeng.guns.base.auth.model.LoginUser;
import cn.stylefeng.guns.base.pojo.page.LayuiPageInfo;
import cn.stylefeng.guns.sys.modular.dbServicelist.model.params.DbServicelistParam;
import cn.stylefeng.guns.sys.modular.dbservicedetails.entity.DbServicedetails;
import cn.stylefeng.guns.sys.modular.dbservicedetails.entity.TableDetails;
import cn.stylefeng.guns.sys.modular.dbservicedetails.model.params.DbServicedetailsParam;
import cn.stylefeng.guns.sys.modular.dbservicedetails.model.result.DbServicedetailsResult;
import cn.stylefeng.guns.sys.modular.metadata.model.result.MetadataResult;
import com.alibaba.fastjson.JSONArray;
import com.alibaba.fastjson.JSONObject;
import com.baomidou.mybatisplus.extension.service.IService;
import io.swagger.models.auth.In;

import java.util.List;

/**
 * <p>
 * 服务详情  服务类
 * </p>
 *
 * @author zhaoyiheng
 * @since 2020-08-21
 */
public interface DbServicedetailsService extends IService<DbServicedetails> {

    /**
     * 新增
     *
     * @author zhaoyiheng
     * @Date 2020-08-21
     */
    void add(DbServicedetailsParam param, LoginUser user);

    /**
     * 删除
     *
     * @author zhaoyiheng
     * @Date 2020-08-21
     */
    void delete(DbServicedetailsParam param);

    /**
     * 更新
     *
     * @author zhaoyiheng
     * @Date 2020-08-21
     */
    void update(DbServicedetailsParam param);

    /**
     * 查询单条数据，Specification模式
     *
     * @author zhaoyiheng
     * @Date 2020-08-21
     */
    DbServicedetailsResult findBySpec(DbServicedetailsParam param);

    /**
     * 查询列表，Specification模式
     *
     * @author zhaoyiheng
     * @Date 2020-08-21
     */
    List<DbServicedetailsResult> findListBySpec(DbServicedetailsParam param);


    /**
     * 通过数据库找元数据
     * @param param
     * @return
     */
    List<MetadataResult> queryMetadataByDatabase(DbServicedetailsParam param);

    /**
     * 查询分页数据，Specification模式
     *
     * @author zhaoyiheng
     * @Date 2020-08-21
     */
    LayuiPageInfo findPageBySpec(DbServicedetailsParam param);

    /**
     * 点击表格某行数据获取该行表的详细信息
     */
    JSONObject queryTableDetails(DbServicelistParam param, String tableName, Integer page, Integer limit);

}
